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(57) Abstract 

In a data processing system (10) having linked lists (400, 400', 500. 500') it is useful to be able to add and delete items 
from such lists (400, 400', 500, 50C) while maintaining the integrity of the linked nature of such lists (400. 400\ 500, 500'). A i 
new compare and swap instruction provides for effectively simultaneously swapping 2 values which is useful for safely ad- , 
ding and deleting items (404, 512) from linked lists (400, 400*, 500, 500*). Prior to the instruction the status of the two values • 
arc read at the locations to be swapped. During the instruction these locations are checked again to ensure that no change I 
has occurred at these locations before the instruction performs the swap of the two new values. The instruction then per- ' 
forms the proposed 2 value swap but only if no change has occurred at these two locations where the swap is to be per- • 
formed. i 
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METHOD AND APPARATUS FOR A COMPARE AND SWAP INSTRUCTION 



Field of the invention 

The subject application relates to instructions for 
data processors, and more particularly, to instructions for 
manipulating items in a list in a data processor. 



Background of the invention 

One aspect typical of a data processing system is 
operating with lists. Each, list is comprised of a number 
of items. Each item is something to be performed or used 
by the data processing system. Items are typically 
processes, data, programs, or subroutines. One way of 
keeping track of a list is to have a head pointer and a 
tail pointer for each list. The head pointer points to the 
first item in the list. The tail pointer -points to the 
last item in the list. In a singly-linked list the first 
item has a next pointer which points to the next item in 
the list which is then the second item in the list. The 
second item has also a next pointer which points at the 
item which follows next after the second item which is then 
the third item. The third item similarly has a next 
pointer which points at the fourth item, and so forth to 
the last item in the list. The last item also has a next 
pointer., but since it is the last item, its next pointer is 
typically null (all zeros). 

Another type of list which offers advantages relative 
to speed of traversing the list is the doubly-linked list. 
In such a list each item has not only a next pointer but 
also a back pointer. The back pointer is used to point 
just ahead in the list. For example, the back pointer of 
the third item in the list points to the second item while 
the next pointer of the third item points to the fourth 
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item. The last item's next pointer is still null while its 
back pointer points to the next-to-last item r assuming of 
course that the list has more than one item. For the first 
item in the list the back pointer is null in view of there 
being no item ahead of it, «and the next pointer points to 
the second item. 

During the operation of the data processing system it 
is desirable to add and delete items from lists. One 
technique that has been developed in a mainframe data 
processing system for such an operation for singly-linked 
lists is an instruction called "compare and swap". The 
instruction can be used to cause the proper adjustment to 
the head pointer of the list so that an item can be added 
or deleted at the head of the list. Before the compare and 
swap instruction is excuted, however, the address in the 
head pointer is read and stored. Then if, for example, a 
new item is to be added, a swap value which can be 
substituted into the head pointer is prepared. This swap 
value when so substituted will cause the header pointer to 
point at the new item. The preparation of the new item 
includes causing its next pointer to point at the next 
following item which is the item which is at the head of 
the list prior to the addition of the new item. After the 
new item is ready, the stored address is compared to the 
address in the head pointer to make sure they are still the 
same. During the preparation of the new item, the list may 
have been altered causing the next pointer of the preceding 
item to also have been altered. If the compared addresses 
are different, the process must start over. If the 
compared addresses are the same, an address pointing to the 
new item (the swap value) is inserted into the next pointer 
of the preceding item, thus effecting the addition of the 
new item. As previously stated, lists often have tail and 
head pointers for assisting in keeping track of the lists. 
Such a compare and swap operation is not effective for 
adding or deleting at the end of the list ev n when the 
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list has head and tall pointers. This is because not only 
the tail pointer must be changed but also the former last 
item must be changed to point at the new last item. This 
has not been available. Similarly, insertion and deletion 
was not available in the middle of a list because the item 
that is to point at the new item (in the case of a new item 
being added) may have been moved to a different list. 
Consequently, the compare test may be passed but the new 
item would be inserted into the wrong list. 

Summary of the Invention 

An object of the subject invention is to provide an 
improved compare and swap instruction. 

Another object of the invention is to provide an 
improved technique for changing two values in a data 
processing system. 

Yet another object of the invention is to provide an 
improved technique for manipulating linked lists in a data 
processing system. 

These and other objects of the invention are achieved 
in a data processor in which two values are to be changed 
effectively simultaneously. A first compare value is read 
at a first location where a value is to be changed. A 
second compare value is read at a second location where a 
value is to be changed. A first swap value is stored which 
is the value to be substituted for the value at the first 
location. A second swap value is stored which is the value 
to be substituted for the value at the second location. An 
instruction which is uninterruptable can then commence. 
The instruction compares the first compare value to the 
value present at the first location, and the second compare 
value to the value present at the second location. If the 
first and second compare values are the same as the 
respective values at the first and second location, the 
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first swap value is input to the first location, and the 
second swap value is input to the second location. 

Brief Description of the Drawings 

FIG* 1 is a block diagram of a data processing system 
useful for implementing the invention; 

FIG. 2 is a block diagram of the data processor of FIG. 

i; 

FIG.s 3A and '3B, placed top to bottom, comprise a 
micro-control flow diagram according to a preferred 
embodiment of the invention; 

FIG.s 4A and 4B are diagrams of doubly- linked lists 
useful for understanding how to use the present invention 
to add or delete an item at an end of a doubly-linked list; 
and 

FIG.s 5A and 5B are diagrams of singly-linked lists 
useful for understanding how to add or delete an item at 
the middle of a singly-linked list. 

Description of the Invention 

Shown in Figure 1 is a data processing system 10 
wherein logical addresses (LADDR) issued by a data 
processor (DP) 12 are mapped by a memory management unit 
(MMO) 14 to a corresponding physical address (PADDR) for 
output on a physical bus (PBUS) 16. Simultaneously, the 
various logical access control signals (LCNTL) provided by 
DP 12 to control the access are converted to appropriately 
timed physical access control signals (PCNTL) by a modifier 
unit 18 under the control of MMO 14. DP 12 is an example 
of a data processor which is capable of implementing the 
present invention relating to compare and swap 
instructions* 
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In response to a particular range of physical addresses 
(PADDR) , memory 20 will cooperate with an error detection 
and correction circuit (EDAC) 22 to exchange data (DATA) 
with DP 12 in synchronization with the physical access 
control signals (PCNTL) on -PBUS 16. Upon detecting an. 
rror in the data, EDAC 22 will either signal a bus error 
(BERR) or request DP 12 to retry (RETRY) the exchange, 
depending upon the type of error. 

In response to a different physical address, mass 
storage interface 24 will cooperate with MP 12 to transfer 
data to or from mass storage 26. If an error occurs during 
the transfer, interface 24 may signal a bus error (BERR) 
or, if appropriate, request a retry (RETRY). 

In the event that the MMO 14 is unable to map a 
particular logic address (LADDR) into a corresponding 
physical address (PADDR) , the MMO 14 will signal an access 
fault (fault) • As a check for MMO 14, a watchdog timer 28 
may be provided to signal a bus error (BERR) if no physical 
device has responded to a physical address (PADDR) within a 
suitable time period relative to the physical access 
control signals (PCNTL) . 

If, during a data access bus cycle, a RETRY is 
requested, OR gates 30 and 32 will respectively activate 
the BERR and HALT inputs of DP 12. In response to the 
simultaneous activation of both the BERR and HALT inputs 
thereof during a DP-controlled bus cycle, DP 12 will abort 
the current bus cycle and, upon the termination of the 
RETRY signal, retry the cycle. 
* If desired, operation of DP 12 may be externally 

controlled by judicious use of a HALT signal. m response 
to the activation of only the HALT input thereof via OR 
gate 32, DP 12 will halt at the end of the current bus 
cycle, and will resume operation only upon the termination 
of the HALT signal. 



ISOOCIO: < WO 86CKXJ4A 1J_» 



WO 86/00434 



£pCT/US85/00670 



In response to the activation of only the BBRR input 
thereof during a processor-controlled bus cycle, DP 12 will 
abort the current bus cycle, internally save the contents 
of the status register, enter the supervisor state, turn 
off the trace state if on, "and generate a bus error vector 
number. DP 12 will then stack into a supervisor stack area 
in memory 20 a block of information which reflects the 
current internal context of the processor, and then use the 
vector number to branch to an error handling portion of the 
supervisor program. 

Up to this point, the operation of DP 12 is identical 
to the operation of Motorola 9 s MC68000 microprocessor. 
However, DP 12 differs from the MC68000 in the amount of 
information which is stacked in response to the assertion 
of BERR. The information stacked by the MC68000 consists 
of: the saved status register, the current contents of the 
program counter, the contents of the instruction register 
which is usually the first word of the currently executing 
instruction, the logical address which was being accessed 
by the aborted bus cycle, and the characteristics of the 
aborted bus cycle, i.e. read/write, instruction/data and 
function code. In addition to the above information, DP 12 
is constructed to stack much more information about the 
internal machine state. If the exception handler is 
successful in resolving the error, the last instruction 
thereof will return control of DP 12 to the aborted 
program. During the execution of this instruction, the 
additional stacked information is retrieved and loaded into 
the appropriate portions of DP 12 to restore the state 
which existed at the time the bus error occurred. 

The preferred operation of DP 12 will be described with 
reference to Figure .2 which illustrates the internal 
organization of a microprogrammable embodiment of DP 12. 
Since the illustrated form of DP 12 is very similar to the 
Motorola MC68000 microprocessor described in detail in the 
several U.S. Patents cited hereafter, the common operation 
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aspects will be described rather broadly. Once a general 
understanding of the internal architecture of OP 12 is 
established, the discussion will focus on the unique 
compare and swap feature of the present invention. 

The DP 12, like the MC68000, is a pipelined, 
microprogrammed data processor. In a pipelined processor, 
each instruction is typically fetched during the execution 
of the preceding instruction, and the interpretation of the 
fetched instruction usually begins before the end of the 
preceding instruction. In a microprogrammed data 
processor, each instruction is typically fetched during the 
execution of the preceding instruction, and the 
interpretation of the fetched instruction usually begins 
before the end of the preceding instruction. In a 
microprogrammed data processor, each instruction is 
executed as a sequence of microinstructions which perform 
small pieces of the operation defined by the instruction. 
If desired, user instructions may be thought of as 
macroinstructions to avoid confusion with the 
microinstructions, in the MC68000 and DP 12, each 
microinstruction comprises a microword which controls 
microinstruction sequencing and function code generation, 
and a corresponding nanoword which controls the actual 
routing of information between functional units and the 
actuation of special function units within DP 12. With 
this in mind, a typical instruction execution cycle will be 
described. 

At an appropriate time during the execution of each 
instruction, a prefetch microinstruction will be executed. 
The microword portion thereof will, upon being loaded from 
micro ROM 34 into micro ROM output latch 36, enable 
function code buffers 38 to output a function code (FC) 
portion of the logical address (LADDR) indicating an 
instruction cycle. Upon being simultaneously loaded from 
nano ROM 40 into nano ROM output latch 42, the 
corresponding nanoword requests bus controller 44 to 
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perform an instruction fetch bus cycle , and instructs 
execution unit 46 to provide the logical address of the 
first word of the next instruction to address buffers 48. 
Upon obtaining control of the PBOS 16 , bus controller 44 
will enable address buffers' 48 to output the address 
portion of the logical address (LADDR) . Shortly 
thereafter, bus controller 44 will provide appropriate data 
strobes (some of the LCNTL signals) to activate memory 20. 
When the memory 20 has provided the requested information, 
bus controller 44 enables instruction register capture 
(IRC) 50 to input the first word of the next instruction 
from PBOS 16. At a later point in the execution of the 
current instruction, another microinstruction will be 
executed to transfer the first word of the next instruction 
from IRC 50 into instruction register (IR) 52, and to load 
the next word from memory 20 into IRC 50 . Depending upon 
the type of instruction in IR 52, the word in IRC 50 may be 
immediate data, the address of an operand, or the first 
word of a subsequent instruction* Details of the 
instruction set and the microinstruction sequences thereof 
are setforth' fully in U.S. Patent No. 4,325,121 entitled 
"Two Level Control Store for Microprogrammed Data 
Processor" issued 13 April 1982 to Gunter et al, and which 
is hereby incorporated by reference* 

As soon as the first word of the next instruction has 
been loaded into IR 52, address 1 decoder 54 begins 
decoding certain control fields in the instruction to 
determine the. micro address of the first microinstruction 
in the initial microsequence of the particular instruction 
in IR 52. Simultaneously, illegal instruction decoder 56 
will begin examining the format of the instruction in IR 
52 • If the format is determined to be incorrect, illegal 
instruction decoder 56 will provide the micro address of 
the first microinstruction of an illegal instruction 
microsequence. In response to the format error, exception 
logic 58 will force multiplexor 60 to substitute the micro 
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address provided by illegal instruction decoder 56 for the 
micro address provide by address 1 decoder 54. Thus, upon 
execution of the last microinstruction of the currently 
executing instruction, the microword portion thereof may 
enable multiplexor 60 to provide to an appropriate micro 
address to micro address latch 62, while the nanoword 
portion thereof enables instruction register decoder (IRD) 
64 to load the first word of the next instruction from ir 
52. Upon the selected micro address being loaded into micro 
address latch 62, micro ROM 34 will output a respective 
microword to micro ROM output latch 36 and nano ROM 40 will 
output a corresponding nanoword to nano ROM output latch 
42. 

Generally, a portion of each microword which is loaded 
into micro ROM output latch 36 specifies the micro address 
of the next microinstruction to be executed, while another : 
portion determines which of the alternative micro addresses 
will be selected by multiplexor 60 for input to micro 
address latch 62. In certain instructions, more than one 
microseguence must be executed to accomplish the specified 
operation. These tasks, such as indirect address 
resolution, are generally specified using additional 
control fields within the instruction. The micro addresses 
of the first microinstructions for these additional 
microsequences are developed by address 2/3 decoder 66 
using control information in IR 52. In the simpler form of 
such instructions, the first microseguence will typically 
perform some preparatory task and then enable multiplexor 
60 to select the micro address of the microsequence which 
will perform the actual operation as developed by the 
address 3 portion of address 2/3 decoder 66. In more 
complex forms of such instructions, the first microsequence 
will perform the first preparatory task and then will 
enable multiplexor 60 to select the micro address of the 
next preparatory microsequence as developed by the address 
2 portion of address 2/3 decoder 66. Upon performing this 
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additional preparatory task, the second microsequence then 
enables multiplexor 60 to select the micro address of the 
microsequence which will perform the actual operation as 
developed by the address 3 portion of address 2/3 decoder 
66. In any event, the last- microinstruction in the last 
microsequence of each instruction will enable multiplexor 
60 to select the micro address of the first 
microinstruction of the next instruction as developed by 
address 1 decoder 54. In this manner, execution of each 
instruction will process through an appropriate sequence of 
microinstructions* A more thorough explanation of the 
micro address sequence selection mechanism is given in U.S. 
Patent No. 4,342, 078 entitled "Instruction Register 
Sequence Decoder for Microprogrammed Data Processor 0 issued 
27 July 1982 to Tredennick et al, and which is hereby 
incorporated by reference* 

In contrast to the microwords, the nanowords which are 
loaded into nano RON output latch 42 indirectly control the 
routing of operands into and, if necessary, between the 
several registers in the execution unit 46 by exercising 
control over register control (high) 68 and register 
control (low and data) 70. In certain circumstances, the 
nanoword enables field translation unit 72 to extract 
particular bit fields from the instruction in IRD 64 for 
input to the execution unit 46. The nanowords also 
indirectly control effective address calculations and 
actual operand calculations within the execution unit 46 by 
exercising control over AU control 74 and ALU control 76. 
In appropriate circumstances, the nanowords enable ALU 
control 76 to store into status register (SR) 78 the 
condition codes which result from each operand calculation 
by execution unit 46. A more detailed explanation of ALU 
control 76 is given in U.S. Patent No. 4,312,034 entitled 
N ALU and Condition Code Control Unit for Data Processor" 
issued 19 January 1982 to Gunter, et al, and which is 
hereby incorporated by reference. 
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A read-mod if y-wr it cycle (RMC) is available which 
ensures in advance that a write can follow a read without 
relinquishing the bus. This RMC node is indicated by an 
RMC signal. During the RMC mode no other system resource 
can have access to the bus.- The RMC mode and functions 
involved therewith are described in U.S. Patent Mo. 
4,348,722, entitled n Bus Processor", issued Sept. 7, 1982 
to Gunter et al, and which is hereby incorporated by 
reference. The RMC signal can be brought out to an 
external pin to prevent system resources from attempting to 
gain access to the bus when the RMC signal is present. 
Additionally, in the preferred embodiment the RMC signal is 
controlled by microcode. Consequently, instructions can be 
made available which monopolize the bus for even longer 
than the two bus cycles required for a read followed by a 
write. 

Such an instruction which can thus be made available is 
the compare and swap instruction for singly-linked lists 
(CAS1) as previously described. The CAS1 instruction, 
however, is not helpful for doubly-linked lists. A compare 
and swap instruction for doubly-linked lists (CAS2) is the 
subject of the present invention. Shown in PlG.s 3A and 
3B, placed top to bottom, is a micro-control flow diagram 
for performing the CAS 2 instruction according to a 
preferred embodiment of the invention. 

Shown in FIG. 4A is a list 400 comprised of an item 
401, an item 402, and an item 403. Shown in FIG. 4B is a 
list 400* which further includes an item 404 as well as 
items 401-403. Bach item 401-404 has a back pointer and a 
next pointer. The back pointers of items 401-404 are 406, 
407, 408, and 409, respectively. The next pointers of 
items 401-404 are 411, 412, 413, and 414, respectively. 
List 400 also includes a head pointer 416 and a tail 
pointer 417. in list 400 item 401 is the head. 
Accordingly, head p inter 416 points to item 401. As the 
head of the list 400, back pointer 406 of item 401 is null. 
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and next pointer of item 401 points to item 402. Back 
pointer 407 of item 402 points at item 401, and next 
pointer 412 points at item 403. With just three items in 
list 400, item 403 is the last item in list 400. 
Accordingly next pointer 413 of item 403 is null while its 
back pointer points at item 402. Tail pointer 417 points 
at item 403 because it is the last item in the list. Next 
pointer 411-413 and head pointer 416 form a first set of 
pointers which have an analogous function. Beginning with 
head pointer 416 , list 400 can be traversed in a forward 
direction using this set of pointers. Tail pointer 417 and 
back pointers 406-408 form a second set of pointers* 
Beginning with tail pointer 417, list 400 can be traversed 
in a backward direction using the second set of pointers. 

List 400 9 is the same as list 400 except that item 404 
is the last item in the list* Consequently, tail pointer 
417 points at item 404 instead of item 403 and next pointer 
413 of item 403 points at item 404 instead of being null. 
Back pointer 409 of item 404 points at item 403, and next 
pointer 414 is null* Lists 400 and 400' are both properly 
formed doubly-linked lists with head and tail pointers* 
List 400 • can be viewed as list 400 with a new item added 
at the tail. Alternatively list 400 can be viewed as list 
400 1 but with the tail item deleted* A function of the 
CAS 2 instruction is to be able to either add or delete an 
item at the head or tail using uninterruptable cycles. The 
first explanation is for adding an item at the tail* The 
list is originally list 400 which is changed by the CAS 2 
instruction to become list 400 v * 

Before the CAS 2 instruction is performed, item 404 must 
be properly formed* As part of the formation process, item 
404 has its back pointer 409 point to item 403 and next 
pointer 414 null* Also, prior to the CAS 2 instruction, 
tail pointer 417 and next pointer 413 must be read and 
stored* Another step prior to beginning the CAS 2 
instruction is to store the values which are to be put into 
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tail pointer 417 and next pointer 413 so that these 
pointers will point to item 404. These values are 
sometimes referred to as swap values. As shown in FIG.s 1 
and 2 there are numerous registers available for storing 
these swap values. These two pointers are the two that 
must be changed upon the addition of item 404 to list 400 
in order to form list 400*. Tail pointer 417 and next 
pointer 413 must both be changed to point at item 404. 
During the formation of item 404 and after the reading of 
tail pointer 417 and next pointer 413 , list 400 may be 
changed so that item 403 is no longer the last item in list 
400. if that is the case, then at least one of tail 
pointer 417 and next pointer 413 will change, if such a 
change has occurred then item 404 cannot be properly 
added. The CAS 2 instruction ensures that nothing has 
changed which will prevent the proper addition of item 404 
before updating tail pointer 417 and next pointer 413. 
Another characteristic of the CAS 2 instruction is that it 
will continue to completion even if an interrupt is 
received during the instruction. An instruction having 
this characteristic is often called an uninterruptable 
instruction. 

To begin the CAS 2 instruction, the RMC mode is 
instituted and the RMC signal is generated to ensure that 
the CAS 2 instruction has exclusive use of the bus until the 
instruction is terminated. This prevents any changes to 
list 400 except those caused by the CAS 2 instruction 
itself. The values at tail pointer 417 and next pointer 
413 are then consecutively read. These two values are then 
compared to the corresponding values previously stored. 
This can be achieved by subtracting one from the other. if 
the result after subtraction is zero, then the values are 
the same, if the result is other than zero, then the 
values are different, if the values are the same, th n the 
stored values for pointing to item 404 are swapped for 
those values in next pointer 413 and tail pointer 417. 



ISOOCID: <WO RffVUaaAl I > 



WO 86/00434 



14 



PCT/US85/00670 



After this swap the result is shown in FIG. 4B as list 400' 
with it m 404 at the end. If either of the values are 
different, the RMC mode is terminated and the values last 
read from tail pointer 417 and next pointer 413 are stored 
in registers. In view of the changed circumstances as 
indicated by the values being different, a decision is then 
been made available as to the disposition of item 404. If 
item 404 is still to be added, a new CAS 2 instruction can 
be instituted after pointers 409 and 414 have been properly 
updated to reflect the changed conditions. 

Another possibility is for list 400 9 to be the 
beginning point and for the last item in the list, item 
404, to be deleted • In such case list 400 shown in PIG • 
4A is the desired result. As in the case for adding an 
item as previously described, some steps must be taken 
before the CAS 2 instruction begins. In this deletion case, 
next pointer 413 is to swap its value which points to item 
404 for the null value and tail pointer 417 is to swap its 
value which points to item 404 for a value which points to 
item 403. In preparation for this swap, the swap values 
comprising the null value and the value which points to 
item 403 are stored in registers. Also stored in registers 
are the compare values which comprise the value in tail 
pointer 417 which points to item 404 and the value in next 
pointer 413 which also points to item 404. The CAS 2 
instruction is then begun by initiating the RMC mode. The 
test values comprising the values in next pointer 413 and 
tail pointer 417 are then compared to the corresponding 
stored compare values. If each compare value is the same 
as its corresponding test value, the swap values are 
swapped for the corresponding values in next pointer 413 
and tail pointer 417. The result of this swap is list 400 
shown in FIG. 4A« If either of the compare values is 
different than its corresponding test value, then the swap 
does not occur, the RMC mode is terminated, and the new 
values in n xt pointer 413 and tail pointer 417 replace the 
previous compare values stored in registers. 
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The CAS 2 instruction itself which is used to achieve a 
deletion or addition of an item is shown in FIG.s 3A and 
3B. Compare values and swap values must be established 
prior to beginning the CAS2_ instruction. The compare 
values are the ones which are read from the locations which 
need to be changed in order to properly effect the addition 
or deletion of the particular item. The swap values are 
those which are to replace the values in the locations 
which are to have their values changed. After initiating 
the RMC mode, a first test value is read from a first of 
the locations to be changed, a second test value is read 
from the other location while the first test value is 
compared to its corresponding compare value. A compare 
value is said to be corresponding when it was read from the 
same location as the test value to which it was said to be 
corresponding. The second test value is then compared to 
its corresponding compare value if the first test value is 
the same as its corresponding compare value. If not, the 
RMC mode is terminated. If the RMC mode is not terminated 
and if the comparison of the second test value to the 
second compare value shows that these two values are the 
same, then the swap value for the location of the first 
compare and test values is substituted for the first test 
value at that location. The other swap value then replaces 
the second test value at that location. If the second test 
value is not the same as the second test value, then the 
RMC is terminated at that point so that no swap values are 
swapped with the test values. Consequently, any two values 
can be safely swapped ina single instruction. The use is 
not limited to that described for FIG. 4A and FIG. 4B. 

Shown in FIG. 5A is a list 500 comprised of an item 
501, an item 502, an item 503, a head pointer 504, a tail 
pointer 505 and an access counter 506. Access counter 506 
has a value which is incremented every time that a change 
is made to list 500. The value is read or incremented on a 
bidirectional bus 508. Each item 501-503 has a next 
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pointer 509, 510, and 511, respectively. Next pointer 509 
of item 501 points at item 502, next pointer 510. of item 
502 points at item 502, and next pointer 511 of item 503 is 
null. Head pointer 504 points at item 501 which is thus a 
head item. Tail pointer 505 points at item 503 which is 
thus a tail item. List 500 is a properly formed 
singly-linked list having head and tail pointers and an 
access counter. List 500 9 shown in FIG. 5B is the same as 
list 500 except that an item 512 has been inserted between 
items 502 and 503. With item 512 so inserted, next pointer 
510 points at item 512 instead of item 503- as it did in 
list 500. Item 512 has a next pointer 513 pointing at item 
503. List 500* is thus a properly formed singly-linked 
list with one additional item to that of list 500, the 
additional item being inserted in the middle of the list 
between the head and tail items 501 and 503. Whereas FIG.s 
4A and 4B are useful for describing the addition and 
deletion of an item at an end of a list, FIG.s 5A~and 5B 
are useful for describing the addition and deletion of an 
item in the middle of a list. For describing an addition 
or insertion of an item, FIG. 5A shows before and FIG. 5B 
shows after the insertion. Conversely, for a deletion, 
FIG. 5B shows before and FIG. 5 A shows after. 

The insertion of item 512 into list 500 between items 
502 and 503 will- be described first. The changes that need 
to be made to list 500 in order to effect the insertion are 
to next pointer 510 of item 502 and the value in access 
counter 506. Instead of pointing at item 503, next pointer 
510 will point to item 512. Prior to beginning the CAS 2 
instruction, compare values and swap values must be 
stored. The compare values to be stored are those in next 
pointer 510 which points to item 503, and access counter 
506. The swap values are those to be inserted into next 
pointer 510 and provided to access counter 506 to effect 
the insertion of item 512. After the insertion next 
pointer 510 is to have a value which points to item 512, 



4SOOC1D: <wo eeoo*34Ai_i.> 



WO 86/00434 1 7 PCT/US85/00670 



and access counter 506 will be incremented, in order to 
properly prepare item 512 it is necessary to know which 
item is to be after 512 in order to establish where next 
pointer 513 is to point. After item 512 has then been 
properly prepared, the CAS 2 instruction can commence. The 
RMC mode is initiated and next pointer 510 and access 
counter 506 are read. The values at next pointer 510 and 
access counter 506 which are read during the CAS 2 
instruction are check values. Before the swap values 
replace these check values in next pointer 510, it is 
necessary to determine that items 502 and 503 have retained 
their relationship to "each other and that access counter 
506 has not been incremented. While item 512 was being 
formed, one of items 502 or 503 may have been deleted. 
Alternatively, another item or items may have been inserted 
between items 502 and 503. Another possibility is that 
items 502 and 503 may have retained their relationship to 
each other but have been moved to another list. If 
something has changed, it would be improper to insert the 
swap values into next pointer 510 and access counter 506. 
Consequently, the check values are compared to the compare 
values to make certain they are the same before inserting 
the swap values. In particular, the value read at next 
pointer S10 before the CAS 2 instruction commenced is 
compared to the value which is present- at next pointer 510 
after the CAS 2 instruction has commenced, and the value 
read at access counter 506 before the CAS 2 instruction 
commenced is compared to the value which is present after 
the CAS 2 instruction at access counter 506. If the 
comparisons show that the check values equal the compare 
values, then the swap values are inserted into next pointer 
510 and access counter 506 so that next pointer 510 points 
at item 512 and that access counter 506 is incremented. 
When such insertion is made, the result is list 500 • shown 
in PIG. 5B. if either f the comparisons results in 
sh wing that one of the check values is not the same as 
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its corresponding compar value, neither swap value is 
inserted • The comparisons are consecutively done, then if 
appropriate in view of the comparisons, the insertions of 
the swap values are also consecutively done. 

The CAS 2 instruction is also useful for deleting an 
item from the middle of a list, such as deleting item 512 
from list 500 f to obtain list 500. The compare values 
which are read prior to commencing the CAS 2 instruction are 
those at next pointer 510 and access counter 506. The swap 
value for next pointer 510 will be that for pointing at 
item 503* The swap value for access counter 506 will be 
the incremented value of the access counter 506. ^When the 
CAS 2 instruction commences the RMC mode is initiated. A 
first test value is read from either next pointer 510 or 
access counter 506. This first test value is then compared 
to its corresponding compare value, while a second test 
value is read from the other of next pointer 510 or access 
counter 506. If the first test value is not the same as 
its corresponding compare value, then the CAS 2 instruction 
and RMC mode are terminated. If the first test value is 
the same as its corresponding compare value, then the 
second test value is compared to its corresponding compare 
value. If the second test value is not the same as its 
corresponding compare value, the CAS 2 instruction and the 
RMC mode are terminated, and the first and second test 
values replace the compare values. If the second test 
value is the same as its corresponding compare value, the 
swap values are consecutively swapped for the values in 
next pointer 510 and access counter 506. In particular, 
the swap value which is inserted into next pointer 510 
causes next pointer 510 to point at item 503, and the swap 
value which is inserted into access counter 506 is the 
incremented value of the access counter 506. Whether next 
pointer 510 or access counter 506 is updated before the 
other is not significant. After effecting the insertion of 
the swap values, the CAS 2 instruction and RMC mode are 
terminated. The CAS 2 instruction thus effects th deletion 
of item 512 from list 500' to obtain list 500. 
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The CAS 2 instruction is not limited to safely swapping 
2 values in a linked list situation. The instruction can 
be useful anytime it is desirable to simultaneously swap 2 
values, such swapping can involve values of other types of 
list, but may also involve "Values unrelated to lists. The 
CAS2 instruction may be useful in any data structure which 
can have one location changed in conjunction with an 
acccess counter. A tree structure is such a situation 
where it can be useful to swap 2 such values effectively 
s imul taneous ly . 

The microcode for achieving this CAS 2 instruction is 
disclosed in appendices I and II. 
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APPENDIX Z 
MICROINSTRUCTION LISTING 



♦ CO-ORDINATE OF BOX MICRO SEQUENCER 

+ LABEL OF BOX INFORMATION 

I + — MICRO ADDRESS J 
| - + — ORIGIN I 
V V V V V 
+ + + + -+ + 

IAA1I EX AMI | 040 I EX AMI (1) ( Al | 
+__-+_+.+..+—+.—. i— <._.._+_.. ——+——+ 

| SIZE | PADB | RXS| RYS| R/W TIME TYPE) 
+ ■+ + + — + •+ -+ 



+< 



"COMMENTS" 




AU 


TRANSFERS 




ALU 


» Tl 


DESTINATION 


CC 


> T3 


DESTINATION 


SHFTO 






SHFTC 






FTU 






PC 






PIPE 






DATE 



ORIGIN: if shared, co-ordinate of origin 

if origin, # of boxes sharing with this box 



DATA ACCESS INFORMATION: 
R/W 

• -no access 
<W> - write 
<> - read 

SPC - special signal 
EXL - latch exception 



TIME 

X - no timing associated 
Tl - write to aob in Tl 
T3 - write to aob in T3 
T0 - aob writen before Tl 



TYPE 

. ,<>,<W> on R/W 
• - normal access 

DNK - program/data access 
CNORM - conditional normal 
CUNK - conditional prog/data 
AS - alternate address space 
CPU1 - cpu access - different bus error 
CPU2 - cpu access - normal bus error 
RMC - read-mod if y-write access 
SPC on R/W 

RST1 - restore stage 1 
RST2 - restore stage 2 
HALT - halt pin active 
• RSET - reset pin activ 

STNC - synchronize machine 
EXL n R/W 

BERR - bus. error PRIV - privilege viol. 

AERR - address err r TRAC - trace 
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LINA - lin a 21 

L2MF - lin f 

ILL - illegal 

DVBZ - divide by zero 

bdck - bad check 

TRPV - trap on overflow 

MICRO SEQUENCER INFORMATION:- 



TRAP - trap 

COP - protocol viol. 

PORE - fomat rror 

INT - interrupt 1st stack 

INT2 - interrupt 2nd stack 

NOEX - no exception 



OB - direct branch - next microaddress in microward 
BC - conditional branch 

Al - use the Al PLA sample interrupts and trace 
A1A - use the Al PLA sample interrupts, do not sample 
trace 

A1B - use the Al PLA do not sample interrupts or trace 
A2 - use the A2 PLA 

A7 - functional conditional branch <DB or A2 PLA) 
A4 - use the A4 latch as next micro address 
A5 - use the A5 PLA 
A6 - use the A6 PLA 

SIZE: 

size ■ byte nano specified constant value 
size - word nano specified constant value 
size ■ long nano specified constant value 
size - ircsz ire [11] -0/1 •> word/long 
size « irsz ird decode of the instruction size 

(byte/word/long). Need to have file 
specifying residual control 
size « ssize shifter control generates a size 

value. The latch in which this value 
is held has the following encoding 

000 - byte 

001 - word 

010 * 3-byte 

011 ■ long 

100 ■ 5-byte *** must act as 
long sized 

RXS - RX SUBSTITUTIONS:' 

RX is a general register pointer, it is used to point 
at either special purpose registers or user registers. 
RX Severally is used to translate a register pointer 
rieid within an instruction into the control required 
to select the the appropriate register. 

rx ■ rz2d/rxd conditionally substitute rz2d 

use rz2d and foree rx[3]*0 

»ul.l 0100 110 0 00 xxx xxx 

div.l 0100 110 991 xxx xxx 
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rx " rx irdlll:9] bu? d oto rx[2:0] 

rx{3) - 0 (data r g.) 

(unless residual points) 
rxa then rx(3] - l 

(residual defined in opmap) 

rx " rz2 irc2U5s-12J muxed onto rx(3:0J 

rx(3] is forced to 0 by residual control 

SJZ'i* 0100 lle 001 xx * xx * 

bit field reg 1110 ixx 111 xxx xxx 

rx " r P rx£3s0] - ar(3:0) 

The value in the ar latch oust be 
inverted before going onto the rx bus 
for movent rl,-(ry) 0100 100 0i x 100 xxx 



rx « rz 



ire 115:12] nuxed onto rx[3:0] 
(cannot use residual control) 



rx * ro2 rx[2:0] « irc2[8:6] 

rx[3] « 0 (data reg.) 

Osed in Bit Field, always data reg 

" " HI points @ cache address register 

rx » vbr points § vector base register 

rx - vatl points « vatl 

tx - <3t points € dt 

rx " C *P rxI3:0] • ar[3:0] 

The value in ar points at a control 
register (i.e. not an element of the 
user visible register array) 

rx - usp rx(3:0] « f 

force effect of psws to be negated (0) 

rx - sp 




BYS - Ry SUBSTITUTIONS: 



* r y ird[2:0] muxed onto ry[2:0] 

ry£3] ■ 1 (addr reg.) unless residual 
points 

ryd then ry[3] - e. (residual defined 
in opmap) 

^ * SI/d«i n ! his * s a c « a «3itional substitution 
ry/dob for the normal ry selection (which 
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23 lij 1U 2t» i^^ r ;^^ dtt,,1 substitutions 

*»* at) with dbin or dob. Th 

X %£! *!. b l n °f dob 18 selected. 
dbiJ f« f*J S f er 18 t0 th * then 
t«SJfr ? bs i ituted while if the 
sS; S f?J t eS. £rOB the " 11S dob 18 

Special case: ird . 2192 Bxx 0ss 000 xxx 

iSJ*/!!* 9 '"*? 31 ' 1 "*) w »»ere if driven 

?Si°d!S e s?- btts wm dtiv * -Jo 



ry « rw2 



ry - rw2/dt 



ry • vdtl 
ry « vat2 
ry » dty 



^sl^w? nuxed onto r yt 3: «J 

move* ea,rl 0100 ii 0 01x xxx XJ£x 

bfield 110 001 xxx xx x 

cop Hi? xxx xxx x " xxx 

do »li T 111 XXX XXX XX* XXX 

d0 d ;;V ll0B " 9 lSS| r " J?«itte„ to 
force ryuj . t " x11 "* xxx 

billil mi "» l'\ *« 

lxx xll xxx xxx 

use rw2 and force ry[3j-0 

0100 lie 000 xxx xxx 

Ai „ , and irc2U0] - 1 

div.l 0100 110 m xxx xxx 

and irc2[10J « l 
points @ virtual data temporary 
points * virtual address temporary 2 
points a dt 



AO - ARITHMETIC UNIT OPERATIONS: 
«- ASOEC add/sub 



1- ASXS 



sub /8 ? b ^r ed °° re8 *d«al control 
sub if ird - xxxx xxx xxx 100 xxx 

add/sub add/sub based on residual (use alu 
add/sub) . do not extend db entr? 

add if ird . 1101 xxx xxx xxx xxx add 



yefWirv -»■«*-» ham m*s . 
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2- SOB 

3- DIV 

4- NIL 
6- SUBZX 

8- AODX8 

9- ADDX6 

10- ADD 

11- MDLT 



sub 
add/sub 



12- ADDXS 

13- ADDSE 

14- ADDZX 

15- ADDSZ 

CONSTANTS 
»rl 

1,2,3,4 



sub 

add 

add 

add 
add 



add 
add 

add 
add 



24 

or "-0101 xxx 0xx xxx xxx addg 

subtract AB from DB 

do add if aat[31] - 1, 
sub if aut[31) - 0; take db (part rem) 
shift by. l shifting in alut[31] then 
do the add/sub. 



zero extend DB according to size then 
sub AB 

sign extend DB 8 -> 32 bits then 
add to AB 

sign extend DB 16 -> 32 bits then 
add to AB 

add AB to DB 

shift DB by 2 then add constant 
sign/zero extend based on residual 
and previous aluop 

amis « always sxtd 

mulu «-sxtd when sub in previous 
aluop 

sign extend DB based on size then 
add to AB 

sign extend DB based on size then 
shift the extended result by 0,1,2,3 
bits depending upon irc(10:9]. 
Finally add this to AB 

zero extend DB according to size then 
add to AB 

zero extend DB according to size, 
shift by 2, then add 



1 selected by: 
(div * allzero) 

selected by size 
byte - 1 
word ■ 2 
3-by - 3 
long « 4 



♦ (mult * alu carry « 0) 
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If (Rx«SP or Ry-SP) and (Ry.Ry or Rx«Rx) and (Rx r Ry is 
a sourc and destination) and (au c nstant - 1,2,3,4) and 
(sir - byt ) then constant - 2 rather than one. 

ALU - ARITHMETIC AND LOGIC ONXT OPERATIONS: 

eolfl « x,nil 
coll • and 

col2 « alul,div,mult,or 
co!3 - alu2,sub 



row 




col 1 


1 


ADDROW 


and 


2 


ADOXROW 


and 


3 


SORROW 


and 


4 


SUBXROW 


and 


5 


DIVROW 


and 


6 


MULTROW 


and 


7 


AND ROW 


and 


8 


EORROW 


and 


9 


ORROW 


and 


10 


NOTROW 


and 


11 


CHGROW 


and 


12 


CLRROW 


and 


13 


SETROW 


and 



col 2 


col 3 


add 




addx 


' add 


sub 




subx 


addl 


div 


sub 


mult 


sub 


and 




eor 




or 


add 


not 




chg 




clr 




set 





add 

addx 

addl 

and 

chg 

clr 

eor 

not 

or 

set 

sub 

subx 

mult 



div 



db + ab 
db + ab 
db 4- ab 
ab * db 
ab xor k«-l 
ab • k»0 
ab xor db 
"ab v db 
ab v db 
ab v k--l 
db 4- ab 
db + ab 



cin 
0 
x 
1 



1 
x 



5f5 5 hi ^ ted b Y 2) add/sub (ab shifted by 0,1.2 
(if 0 then add/sub 0)) control for add/sub and 
shift amount comes from regb. Don't assert a true 
xor mult 

cin ■ 0 

build part, quot and advance part, remain. 1 
ab (pr.l:pq) shifted by 1, add0, 
value shifted in « au carry (quot bit) 

cin • 0 
must assert atrue for div 



isoocit* <wo aaooi34Ai_i_> 



WO 86/00434 



PCT/US85/00670 



26 

Th c ndition codes are updat d during late T3 
bas d upon the data in alut and/or rega. These 
registers can b vrritt n to during ?3. In the 
case of rega, th r are tines when the value to 
be tested is the result of an insertion from regb. 

CC - CONDITION CODE UPDATE CONTROL: 



row 

1 add 

2 addx 

3 sub 
4 ■ subx 

5 div 

6 null 

7 rotat 

8 rox 

9 bit,bitfld 

10 log 



col 1 

cnzvc 
cnzvc 
cnzvc 
cnzvc 

knzv0 (div) 
knzv0 
knzGc 
cnz0c 

kkzkk (bit) 
knz00 



col 2 




col 3 




ddddd 




ddddd 




ddkdc 


(bcdl) 


cdzdc 


(bcd2) 


knzvc 


(cnp) 


ddddd 


ddkdc 


(bcdl) 


cdzdc 


(bcd2) 


ddddd 




ddddd 


ddddd 




ddddd 




ddddd 




-ddddd 




knz00 




kkkvk 




knz00 


(bfldl) 


kkzkk 


(bfld2) 


ddddd 




ddddd 



standard 

n « alut msb (by size) 
z » alut*0 (by size) 



non-standard 
add c « 

v « 

addx «1 c » 
z « 



bcdl 
bcd2 

bfldl 

bfld2 
bit 
div 
mull 



rotat 
rox •! 



rox. 3 



v 
c 
c 
z 
n 
z 
z 
z 

V 

n 



c 
c 



coat 
vout 
cout 

pswz * locz 

vout 

cout 

coot v pswc 

pswz * locz 

shiftend 

all zero 

pswz ~ allzero 

all zero 

au carry out 

(shiftend m irc2(10]) v 

(alut [31] • ~irc2[10]) 
(alut«0 m shift allzero m irc2(10]) v 

(alut«0 * •irc2[10]) 
•irc2I10] • {(irc2[ll] * Callzero • 

•alut 131]) v Callone " alut(31])) v 
rirc2tll] m -allzero)) 
shiftend « (sc«0 - 0 sc<>0 - end) 
shiftend « (sc«0 - pswx sc<>0 - end) 
1 can do this in two steps as knz0c where 
I cpsvx and cnz0c where c«shiftend (not 
1 with share row with shift) 
shift overflow « (Calls r m sc>sz) v 

(~(allz ro v allones) * sc<«sz) ) 
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1 can simplify this if we don't share 



sub, 1 


c 


m 


~cout 




V 




vout 


sub .2 


c 


m 


~cout 




V 




vout 


fiubx # l 


c 


m 


~cout 




z 




pswz • 




V 


m 


vout 


oubx.2 


c 


m 


~cout 


8ubx.3 


c 


m 


~cout < 




z 


m 


pswz • 



locz 



v pswc 
locz 



Ibl ™2fj? and sour ? e •* signals which are used to set 
the condition codes is listed below: *° set 

allzero - every bit in rega field . 0 where the 

? r I s defined as starting at the bit 

It S?w2 S«"S a 5V a S endlns < i »cluding) 
at the bit pointed to by end. 

(see shift control) 

allone . every bit in rega field - i where the 

£ ? ld . i G defi »e<3 as starting at the bit 

It ?J ed v?f by . 8tart and ****B9 (including) 
at the bit pointed to by end. 
(see shift control) 

shiftend « the bit in rega pointed to by end « 1. 
(see shift control) 

locz m all alut for the applicable size « g. 
SHPTO - SHIFTER OPERATIONS: 

Sun? JifaS« i JnSS t SS. r,gl,t by ^ in 8hift 



ror 
sxtd 



7I 1 !!? io re9a def ined b y at **t and end registers 
£2a? i S!!i €Xtended to fil1 the »ndefined Ills ttl 
2j?5* valu# is rota *«<* right by the value il the 
shift count register. ThS result is in regb. 

xxtd yaluein rega defined by start and end registers 

iLS S S, eXt ? nded to £il * tba »« d «fin2d bits iS" 
that value is rotated right by the value in 1*1 
shift count register. Th2 reXl? is i£ ?egb. 

" td SH-^" a sua ,s mint? 
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ins 



boffs 



offs 



28 



the value in r gb is rotated left by th value in 
shift count register and then inserted into the 
field defined by the start and end register in 
rega. Bits in rega that are not defined by start 
and end are not modified. 

provides the byte offset in regb. If irc2[llj«l 
then the offset is contained in RO and as such 
rega should be sign extended from rega to regb' 
using the values established in start, end, and 
shift count of 3,31,3 respectively, if irc2[ll]«0 
then the offset is. contained in the immediate 
field and should be loaded from irc2[10:6) or 
probably more conveniently osr(4s0]. This value 
however should be shifted by 3 bits such that 
osr [4:3] are loaded onto regb[l:0] with zero 
aero extension of the remaining bits, 
provides the offset in regb. if irc2[ll]«l then 
the offset is contained in RO and as such DB>REGB 
should be allowed to take place. If irc2[ll]»0 
then the offset is contained in the immediate 
field and osr[4:0] should be loaded onto regb 14:0] 
with zero extension of the remaining bits. 



SHPTC - SHIFTER CONTROLS 



{sbml} 
BIT st • 0 

bit en « -1 
mvp sc « wr 
swap wr « BC[12:7] 
callm osr * x 

cnt « x 



(31) 

(16,32) 

(16,32) 



{sbm3} 

st - DB [5:0] mod sz 

en - DB [5:0] mod sz 
sc « 0 

wr ■ OB [5:0] 
osr ■ x 
cnt - x 

(sbm5) 
st - x 
en ■ x 
sc » x 

wr » DB 17:2] 
osr ■ x 

cnt[l:0] » DB [1:0] 



(sbm2) 
st « wr 
en - wr 
sc » wr 
wr « wr 
osr » x 
cnt « x 

{sbm4} 
st « 0 
en » -1 
sc * wr 
wr » wr 
osr « x 
cnt « x 

{sbm6} 
st « 16 
en «= 31 
sc « 16 
wr « wr 
osr - x 
cnt - x 



8 
1 
8 
8 



(31) 



- 1 



{} 
st 
n 
sc 



x 
x 
x 
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wr ■ x 
osr - x 
cnt - x 

{null} 
HDL st - wr 
nulw en - -1 nod sz 
null sc ■ wr 

wr « BC[12:7] 

osr « x 

cnt » x 

{nul3} 
st * 0 
en - -l 
sc ■ x 
wr * x 
osr ■ x 
cnt • x 

{} 

st « X 
en « x 
sc « X 
wr « x 
osr ■ x 
cnt • x 

{} 

st - x 

en « x 
sc m x 
wr ■ x 
osr « x 
cnt « x 

{divwl} 
divw st * 0 
en - 31 
sc ■ wr 
wr » BC(12:7] 
osr - x 
cnt ■ x 

{divw3} 
s t • wr 
en • -l 
sc • wr 
wr • BC [12:7] 

sr ■ x 
cnt - x 

{divwS} 
st ■ 4 



(15,.31) 
(14,30) 



(31) 



(10) 
(10) 



(16) 
(31) 
(16) 
(16) 



<nol2} 
st ■ wr 
en ■ wr 
sc - wr 
wr • wr 
osr • x 
cnt « x 

{mul4} 
st « 0 
en ■ en 
sc * x 
wr « x 
osr - x 
cnt « x 

(mul6) 
st « 16 
en « 31 
sc » 16 
wr - x 
osr « x 
cnt « x 



- 2 

- 2 

- 2 



{divw2} 
st • 0 

en » -1 mod sz 

sc - 16 

wr • wr - 1 

osr ■ x 

cnt « x 

{divw4} 
st ■ 0 
en ■ 31 
sc ■ wr 
wr - x 

sr * x 
cnt • x 

(divw6) 
st ■ 16 



(15) 
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en - -1 nod six (7) 
sc - 28 
wr • x 
osr « x 
cnt • x 

{divw7} 

St ■ St 

en « -1 (31) 

BC » 0 

wr * x 
osr * x 
cnt « x 

{divll} 

divl st - wr - 1 (31) 
en « -1 (31) 

SC « X 

wr » BC[12:7] (32) 
osr « x 
cnt « x 



{divl3} 
st » 0 

en « -1 (31) 
sc * 0 
wr « x 
osr * x 
cnt » x 

O 

St * X 

en » x 
sc * x 
wr * x 
osr « x 
cnt » x 

U 

St * X 

en « x 
sc • x 
wr » x 
osr * x 
cnt ■ x 

U 

St « X 

en ■ x 

SC * X 

wr » x 
osr « x 
cnt « x 



unk 



n « 31 
sc - 16 
wr ■ x 
osr » x 
cnt » x 



{aivl2} 
st « 0 
en * -1 
sc ■ 0 
wr * wr 
osr « x 
cnt * x 

{divl4} 
st « 0 
en - 31 
sc « 0 
wr « x 
osr * x 
cnt * x 

{divl6} 
st « 16 
en « 31 
sc * 16 
wr » x 
osr « x 
cnt * x 



(31) 



• 1 



O 

st « x 
en ■ x 

SC * X 

wr * x 
osr « x 
cnt * x 
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{) 

st - x 
en » x 
sc • X 
wt ■ X 
osr « x 
cnt - x 



{} 

St » X 

en • x 
sc » x 
wr • x 
osr « x 
cnt ■ x 



{) 

St - X 

en ■ x 
sc - x 
wr • x 
osr » x 
cnt « x 



(unkfi) 
st - 16 
en - 31 
sc « 16 
wr ■ x 
osr - x 
cnt - x 

U 

st - X 
en • x 

SC * X 

wr » x 
osr « x 
cnt « x. 

asl st * 0 (asl2> 

en ■ osr ♦ "wr st « x 

sc - -wr + l en " < wr "D »od sz 

wr « DB IStd} or BCI12:7J (Q) wr - wr 

osr * BC[5:01 /a i« i«5? 

»v-ia.»j (0,16,32) osr « osr 

* cnt - x 

wr « wr sc - x 

osr « x wr - wr 

cnt - x osr - x 

cnt - x 

it - x 

en « x st - 16 

sc - x en - 31 

wr . x sc * 16 

osr - x wr - x 

cnt - x osr - x 

cnt ■ x 

{} 

st « x 
en ■ x 
sc » x 
wr ■ x 
osr ■ x 
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cnt ■ x 

(asrl) 
asr st « wr 

en * osr - 1 
sc « wr 

wr - DB [5:0] or BC[12:7] (Q) 
osr - BC[5:0] (8,16,32) 
cnt. » x 

{asr3} 

st ■ osr - 1 
en * osr - 1 

SC * X 

wr « wr 
osr « osr 
cnt * x 

U 

St « X 

en * x 

SC « X 

wr * x 
osr * x 
cnt * x 

{> 

St « X 

en - x 
sc » x 
wr « x 
osr * x * 
cnt « x 



£asr2) 

st - wr - 1 

en « (wr - 1) -mod sz 

SC « X 

wr * wr 
osr * osr 
cnt » x 

•* 

{} 

St * X 

en m x 
sc - X 
wr - x 
osr « x 
cnt ■ x 

Usr6) 
st « 16 
en « 31 
sc « 16 
wr * x 
osr • x 
cnt « x 



rotl 



(31) 



{rotll} 
st ■ osr 
en « -1 
sc * osr 

wr « DB [5:0] or BCI12:7] (Q) 
osr « BC[S:0] (8,16,32) 
cnt » x 



{rotl3} 
st * 0 
en « 31 
sc » "(wr 
wr * wr 
osr * osr 
cnt « x 



- 1) mod sz 



u 

st 
en 
sc 



X 
X 
X 



{rotl2} 
st « x 
en » "(wr 

SC ■ X 

wr « wr 
osr « osr 
cnt « x 

O 

st « x 
en « x 
sc « x 
wr ■ x 
osr « x 
cnt « x 

{rotl6} 
st « 16 
en « 31 
sc » 16 



• 1) mod sz 
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wr ■ x 
osr - x 
ent - x 

{} 

St - X 

en - x 
sc » x 
wc » x 
osr - x 
cnt ■ x 

{rotrl} 
zotr st - osr 

en - -1 (3i) 
sc ■ osr 

wr « DB [5:0] or BCI12:7) (Q) 
osr - BC[5:0] (8,16,32) 
cnt « x 

{rotr3} 
st * 0 
en » 31 

sc - wr mod sz 
wr ■ wr 
osr ■ osr 
cnt « x 

{> 

St * X 

en « x 
sc ■ x • 
wr « x 
osr » x 
cnt ■ x 

{} 

St « X 

en « x 
sc « x 
wr • x 
osr - x 
cnt - x 



wr » x 
osr • x 
cnt ■ x 



{rotr2} 
st « x 

en ■ (wr - 1) aod sz 
sc ■ X 
wr * wr - 
osr « osr 
cnt « x 

{> 

St « X 

en « x 

SC ■ X 

wr ■ x 
osr » x 
cnt * x 

{rotr6} 
st - 16 
en ■ 31 
sc • 16 
wr ■ x 
osr - x 
cnt ■ x 



{roxll} 
zoxl st « 0 

en ■ osr ♦ "wr (14) 

sc - -1 (3i) 

wr * BC [12:7] (l) 

osr « BC[5:0] (16) 
cnt « x 

(roxl3) 

st ■ C(wr-l) + i) nod sz 



{roxl2} 
st » 0 
en « (osr 
sc - 0 

wr ■ wr 
osr * osr 
cnt « x 

{rox!4} 
st « 0 



- wr) mod sz 
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en « -1 mod sz 

sc - C(wr-l) + 1) nod sz 

wr m ob [5:0] or BC[12:7] (Q) 

osr « BC[5:0] (8,16,32) 

cnt « x 

CroxlS) 

st » C(wz-l) ♦ 1) mod sz 

en » -1 mod sz 

cc « (~(wr-l) + 1) mod sz 

wr ■ wr 

osr » osr 

cnt • x 

{roxl7} 
st * wr - 1 
en • osr - 1 
sc * 0 
wr « wr 
osr * osr 
cnt « x 



en ■ sr + wr 
sc « "wr + 1 
wr ■ wr 
osr « osr 
cnt « x 

{roxl6} 
st « 16 
en « 31 
sc - 16 

wr ■ wr - 1 - osr 
osr * osr 
cnt « x 



{roxrl} 
roxr st « wr 

en » osr - 1 
sc « wr 
wr « BC[12:7] 
osr « BC[5:0] 
cnt » x 

{roxr3} 
st * 0 

en * (wr-1) - 
sc * (wr-1) + 
wr * DB [5:0] 
osr * BC[5s0] 
cnt * x 

{roxrS} 
st « 0 

en « (wr-1) - 
sc « (wr-1) + 
wr * wr 
osr * osr 
cnt m % 

{roxr7} 
st * 0 

en « osr - wr 
sc - 0 
wr * wr 
osr « osr 
cnt « x 



(1) 
(16) 



24,16,0 

or BC[12:7] (Q) 
(8,16,32) 



1 

24,16,0 



{roxr2} 
st « 0 

en » (wr - 1) mod sz 
sc * 0 
wr ■ wr 
osr « osr 
cnt « x 

{roxr 4} 
st ■ wr 
en « osr - l 
sc « wr 
wr * wr 
osr « osr 
cnt * x 

{roxr6} 
st « 16 
en - 31 
sc - 16 

wr « wr - 1 - osr 
osr « osr 
cnt « x 
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bf reg 



bfmt 



{bfrgl} 

st • 0 

en - 31 

sc ■ obz ♦ wr 

wr - DB[4:0] or IRC2(4:0] 

osr - REGB(4:0) or IRC2[10:6) 

cnt • x 

(b£rg3) 

st » 0 

en - 31 

ec » osr + wr 

wr ■ wr 

osr ■ osr 

cnt » x 



{bfrg5} 
st ■ x 
en » x 
sc « x 
wr • wr 
osr » x 
cnt [1:0] 

(bfrg7) 
st - 0 
en * 31 
sc « 25 
wr « x 
osr ■ x 
cnt » x 

{bfmtl} 
st « 3 



OB [1:0] 



en 



-1 



(31) 



SC m 3 

wr * DB[4:0] or IRC2[4:0] 
osr « RBGB[4:0] or IRC2[10:6] 
cnt « x 



{bfmt3> 
st - 0 

en - ll:"osr[2:0] 
sc * 0 
wr « wr 
osr. ■ osr 
cnt « x 



<bfrg2) 
st « 0 
en » wr - 1 
sc • 0 
wr ■ wr 
osr ■ osr 
cnt * x 

O 

St - X 

en - x 

SC » X 

wr • x 
osr « x 
cnt » x 

{bfrg6} 
St « 16 
en - 31 
sc ■ 16 
wr » wr 
osr ■ osr 
cnt ■ x 



{bfmtS} 
st ■ x 



{bfmt 2} 
st - 00: 

"(osr [2:0]+(vr-l) ) 
en - (osr [2:0]+(wr-l) ) 

[4:3] :"©sr [2:0] 
sc « 0 
wr ■ wr 
osr ■ osr 
cnt • (osr[2:0]+ 

(wr-1)) [5:3] 

{bfmt 4} 
st * 00: 

"(osr [2:0]+(wr-l) ) 
en • -l nod sz (7) 
sc » 0 
wr » wr 
osr » x 
cnt » x 

{bfmt 6} 
st « 16 
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en ■ x 

6C * X 

wr ■ x 
osr « x 
cnt ■ x 

{bfmt7} 
st « x 
en » x 

SC « X 

wr « x 
osr ■ x 
cnt « x 



36.. 

en - 31 
sc « 16 
wr ■ wr 
osr ■ osr 
cnt « x 



bfmi 



{b£mil} 
st « 3 

en » -1 

sc * 3 



(3D 



wr * DB[4:0J or IRC2[4:0] 
osr « REGB [4:0] or IRC2[10:6] 
cnt * x 



{b£mi3) 
st - 0 

en * ll:~osr[2:0] 

sc - ll:-(osr[2:0]+(wr-l)) 

wr « wr 
osr ■ osr 
cnt « x 

{bfoi5} 
st - 0 

en • 00: (osr [2:0]+ (wr-1) ) 
sc » 25+ (00: 

(osr [2:0]+(wr-l))> 
wr • wr 
osr « x 

cnt[l:0] » DB [1:0] 

{bfmi 7} 
st - 0 
en - 31 
sc - 25 
wr ■ x 

sr » x 
cnt « x 



(bfmi2) 
st m 00? 

"(osr [2:0] + (wr-1)) 
en - (osr [2:0]+(wr-l) ) 

[4:3] :'osr [2:0] 
sc » 00: 

~(osr[2:0]+(wr-l)) 
wr ■ wr 
osr ■ osr 
cnt * (osr [2:0]+ 

(wr-l)> [5:3] 

{bfni4} 
St m 00 • 

•(osrI2s0]+(wr-l)) 
en « -1 mod sz (7) 
sc » 00: 

~ (osr [2:0]+ (wr-1)) 
wr ■ wr 
osr * x 
cnt « x 

{bfmi 6} 
st * 16 
en « 31 
sc « 16 

wr « wr 
osr * osr 
cnt « x 
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(copl) 

cop 



Icopl) 

St * X 

en « x 

SC » X 

wr ■ x 
osr ■ x 
cnt «x 


{cop2} 

St * X 

en « x 

SC * X 

wr * wr 
osr » x 

Cut • X 


(cop3) 
st * X 
en m % 

SC m X 
WT ■ X 

osr m x 
cnt ■ x 


{ cop4 } 

St m X 

en « x 

SC « X 

wr « x 
osr ■ x 
cnt * x 


{copS} 

St ■ X 

en ■ x 

SC ■ X 

wr • DB 17:2] 
osr - x 

cnt(ls0] « DB [1:0] 


{cop6> 
st « 16 
en ■ 31 
sc « 16 
wr « x 
osr « x 
cnt ■ x 


{cop7} 

St « X 




en ■ x 




sc - X 




wr m x 




osr « x 




cnt « x 





*1* loaded based on ird[5] - if ird[5J - 0 then wr 
value comes from BC bus else value is loaded 
from regc. 

PTO - FIELD TRANSLATION UNIT OPERATIONS: 

3- locr load the control register from regb. The 

register is selected by the value in 
ar[l:0] ,» this can be gated onto the rx bus. 

4- DPSW load the psw with the value in regb. Either 

i?L CC T* 0r , tbe psw is lo » de <3 depending upon 

£jJ!«~ Xf 8ize " byte tnen onl * the ccr 

portion* 

14- CLRPP clear the f-trace pending latch. (f P end 2 

17. LDSH2 load th c ntents of the shifter control 
r gist rs from regb. These includ 
wr,osr,c unt. 
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19- LDSHB 

21- LDSWI 
23- LDSH1. 

25- LDOPC 

26- LDPER 

28- LDARL 

29- 0PSWM 
33- RPER 



load th int rnal bus r gister from regb. 
This is composed of bus controller state 
information which must be accessed by the 
user in fault situations. 

load the first vord of sswi (internal 

fifS S *° rd i , fron re9b « Tnis is composed of 
tpend, fpendl, fpend2, ar latch 

load the contents of the shifter control 
registers from regb. These include 
st,en,sc. 

validity of rev #. 

load per with the value on the a-bus. 
(should be a T3 load). ab>per 

load the ar latch from regb. May be able to 
share with ldswi or ldswj 

clear the psw master bit. 

load output of per into ar latch and onto 

5L US - J here , are two operations which 
use this function, HOVEM and BFFFO. MOVEM 
requires the least significant bit of the 
lower word (16-bits only) that is a one^o 
be encoded and latched into the AR latch 

ST.*? t 5\ 8C B ? S (Averted) so that it 
can be used to point at a register, if no 

»i£?„ are K? ne ? hen the end signal should be 

active which is routed to the branch pla. 

^te? doing the encoding, the least 

significant bit should be cleared. 

s?on?!T!^\i? n^essary to find the most 

HI £i? ant bit of a lon 9 word that is a 
one. This value is encoded into 6 bits 

"^i" 08 * 6i 9nificant bit is the 
32-bit all zero signal. Thus the following 

encoding* yUM the ~"««P°nding 9 



most sig bit set 
31 
16 
0 

NONE 



per out 
0 11111 
0 10000 

0 00000 

1 11111 



onto be bus 
1110 0000 

1110 1111 

1111 1111 
0000 0000 



2L, 0U X U ? is . tne n gated onto the BC bus 
where it is sign extended to an 8-bit 
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34- STCR 

37- STPSW 

38- 0PEND 

39- 1PSWS 

40- STIMST 

41- STIRD 
43- STINL 



39 

Zll-V lt do s not nurt anything in the 

llllZ case , to load the oth r latch (i. . 

BFPFO can load the AR latch). 

For BFPFO it does not natter if a bit is 

cleared. 

store the contrpl register in regb. The 
re ?, £f r is selected by the value in 
«r[l:0], this can be gated onto the rx bus. 

store the psw or the ccr in regb based on 

SJfS'vff 6 i zs " bvt e then store ccr only 
with bits 8 - 15 as zeros. 

store the psw in regb then set the 
supervisor bit and dear the trace bit in 
the psw. Tpend and Fpend are cleared. The 
whole psw is stored in regb. 

store the psw in regb then set the 
supervisor bit and clear both trace bits in 
the psw. The whole psw is stored in regb. 

store ird decoded information onto the bc 

5SL a ;S in i°v re9b - This data can °e latched 
from the BC bus into other latches (i.e. wr 
i osr) by other control. 



store the ird in regb. 

J^J e iJl e ln £? rr »Pt level in pswi and 
regb. The three bits are loaded into the 
corresponding pswi bits. The sane three 

S„! S rff e .} oad f d onto bc bus * 3ll J w *th bc 
?«;JJi ! J 3 Z, 1 and W ■ 1. *«ich is loaded 
into regb. Clear IPEND the following Tl. 

44- STV# store the format 6 vector number associated 
with the exception in regb. 

| X| X| FORMAT* r*r«i"" + ""vBCT0R + M0KBER"" 4 ""'! 
15 14 13 12 11 10 9 8 7 € 5 4 I I I ? 
47- STCRC 



48 STSH2 



store the contents of the CRC register in 
regb. Latch A4 with nicroaddress! 

S^f^ 1 " 5 cont ents of the shifter control 
r gisters into r gb. These include 

cont"l COUnt " St ° re hi9h pottlon of *hift 
50- STSWB store the internal bus register in r gb. 
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This is composed of bus controller state 
infonnati n which must b access d by th 
user in fault situations. 

52* STSWI store sswi (internal status word) in regb. 

The sswi is composed of tpend, ar latch, • 
fpendl, fpend2 

54- STSH1 store the contents of the sbifter control 
registers into regb. These include 
st r en,sc. 

56- STOPC store the micro pc in regb. 

+--+--♦ — +—+—+—+—+ — ♦—+—+—+—+—♦— 

| REV NUMBER | CRC | MICRO PC I 

♦ —+—♦—♦ +—+—+—+ + + + + 4 4- 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 

62- NONE 

63- STPER store the per onto the a-bus. (should be a 

Tl transfer) • per>ab 

PC - PC SECTION OPERATIONS S 

AOBPtl] 
0 1 



31 


- 3PFI 


1 EV3PI 1 


1 OD3FI 1 


30 


- 3PFF 


1 TPP 


1 EV3FI 1 



0- NF 

aobpt>db>sas 
tp2>ab>sas 

1- TPP 

aobpt>db>tpl 

aobpt>db>aup>aobp* , aobpt 

+2>aup 

tpl>tp2 

tp2>ab>sas 

2- PCR 

tp2>ab>a-sect 

(if ry«pc then connect pc and address section) 
aobpt>db>sas 

3- PCRF 

aobpt>db>tpl 

a bp t>db>aup>aobp*, aobpt 
+2>aup 

tpl>tp2 

tp2>ab>a-sect 
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(if ry-pc then conn ct pc and address section) 

4- JMP1 

tp2>db>a-sect 
a-8ect>ab>aobpt 

5- BOB 

aobpt>db>tpl 

tpl>tp2 

tp2>ab>sas 

- EV3FI 

aobpt>db>tpl* 

aobp t>db> aup> aobpt 
♦4>aup 

tp2>ab>sas 

- 003FI 

aobpt>db>aup>aobpt , tp2 
+2>aup 

tp2>ab>sas 

7- TRAP 

tp2>db>a-sect 
pe>ab>sas 

8- TRAP 2 

tp2>ab>a-sect 
aobpt>db>sas 

9- JMP2 

a- sect >ab> aobpt 
aobpt>db>sas 

IB- PCOOT 

pc>ab>a-sect 
aobpt>db>sas 

11- NPC Conditional update based on cc-t/f 

tp2>db>aup,a-seet ' 
a-sect>ab>aup> aobpt 

12- LDTP2 

a-sect>ab>tp2 
aobpt>db>sas 

13- SAVE1 

pad>aobp 

aobpt>db>sas 

tp2>ab>sas 

15- SA^E2 

aobp>db>tpl 
tp2>ab>sas 
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14- FIX 

aobpt>db>tpl 
tp2>ab>aobpt 
tpl>tp2 

16- LDPC 

tp2>pc 

aobpt>db>sas 
tp2>ab>sas 

PIPE - PIPE OPERATIONS: 

Description of bit encodings. 
[6] ■ use ire 
[5] • change of flow 
C4] - fetch instruction 
[3:0) » previously defined pipe control 
functionality. 



AOBPI1] 
0 1 

0 113- 3DDI I EV3Pa J OD3P 
10 17- 30DP I TOO J EV3Fb 



.- EV3Fa 

chrl>irb 

chr h>pb> inh , iml , i r c 
change of flow 
fetch instr 

- EV3Fb 

chrl>irb 

chrh>pb> imh , iml t i re 

irOir l implies use ire 

use pipe 
fetch instr 

- OD3F 

chrl>pb>irc 

1 force miss regardless of whether odd or even 
change of flow 
fetch instr 

0 0 0 0 - HOD 
x 

10 0 0- OPIPE 
use pipe 

0 0 11- FIX2 Always transfer irb up pipe 
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irJ£i£?<™H <«i < to irc ' im » n <3 ^ irb needs 
irb>pb>imh,iml,irc to be replac d, do acc ss 

. - . «nd transfer chr to irb. 

I force niss regardless of whether odd or even 
change of flow, 
fetch instr 

change of flow 
fetch instr 

0 0 0 2 - I RAO • 
ira>db 

0 g 0 4 - IRTOO 
ir>ird 

0.0 1 5 - FIX1 

chr>irb if ire needs to be replaced, 

do aceess and transfer chr 
i „. to irb ' else no activity. 

fetch instr 

10 0 6- 2TOC 
irc2>irc 
iroir 
use pipe 

0 0 0 8 - CLRA 

clear irc2I14] 
ira>ab 

0 0 0 9 - 0T2RA 
db»ira 
ira>pb>irc2 

0 0 0 11 - ATOC 
db»ira 
ira>pb>irc 

0 0 1 13 - EOT) 

chr > irb 
irb>pb>imh,iBl 
fetch instr 

1 0 0 14 - CTOO 

iroir, ird 
irbMrc 
use pipe 

1 0 1 15 - TUD 



zxtd 8 -> 32 



WO 86/00434 



CT/US85/00670 



44 



chr>irb 

i rb>pb> imh , inl , i r c 
irOir 
use pipe 
fetch instr 

0 1 1 15 - TOAD 
ehr>irb 

i r b>pb> imh , inl , ire 
irOir 

change of flow 
fetch instr 
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APPENDIX II 
MICROINSTRUCTION LISTING 



PAPA CAS 

CAS 2 DWl:DW2 r D01:DQ2, (RZl) : (RZ2) 
Al 

+• + — + + 

|FG1| CASP1 I 367 I 

—+—+—+—}•— —+———. 



|"i>B~~| 



| X | INST J DTI RYJ 

. +— 4- — + -+< 



I 



"STORE 1ST POINTERS" 
IM>DB>DT 

"LATCH RMC ADDRESS INTO A4' 
% AT>DB>SAA 
% AUT>AB>SA 



X 
NIL 
X 
X 
X 

NP 
OPIPE 

1/26 



+- — + + + — 

|FH1| CASP2 I 654 I I DB 1 

+ +-+ + — + +-+ + i + 

I IRSZ | DATA) RZ2| RW2| <> Tl RMC j 

"READ 1ST DEST" * ~X + 

RZ 2 A> DB> > AOB HIL 

RZ2A>DB>A0T X 

"STORE 1ST COMPARE VALUE" X 

RW2D > AB > > RE6B X 

"2ND POINTER TO IRC2" NONE 

• IN>DB»IRA UP 

"FORCE SYNC" OSTIR 
RW2D>AB>>DOB 
% AOT>AB>SAA 

+— +- — — + + ; 



I FI1| CASP3 J 368 1 
+ +-+ -+ — + +-4.. 

| IRSZ | INST I RZ2I 
+ — ---+ + + 



2/17 
I DB | 



RY| <> Tl RMC | 



"READ 2ND DEST" 
RZ2A>AB>>AOB 
"DO 1ST COMPARE" 
DBI N>DB> ALD>ALOT 
REGB>AB>ALO 
"STORE 1ST DEST" 
DBIN>DB>AT 



X 

COL2 
CC2 
X 
X 

NONE 
NF 
NOD 

+ + 1/21 
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+ + ♦ + — +- + 

|FJ1| CASP4 | 652 | CASM2 (FBI) | BC | 



.+-«♦■. 



.4—+- 



| IRSZ|IHST| BX | 
♦ — — + — — + — .... +. 

"DO 2ND COMPARE** 
DBI N>DB> ALO> ALOT 
RW2D>AB>ALO 
"STORE 2ND DEST" 
DB I N> DB> > REG A 
% AT>DB>SAA 
% AOT>AB>SAA 



RW2J 
— — +. 



LOCZ -> CASP9 
'LOCZ -> CASP5 

(CASP4) 



I 

+— + 

X 

COL2 
CC2 
X 
X 

STPSW 
HP 
HUD 

1/10 

+ 

(FL2) 
(FL1) 



1ST COMPARE FAILS 
+ — +- — — + — — +- — — + 

FL1| CASP5 | 729 |ALPS3 (CG5) | DB J 
»■-+—-. — + — + — -+-+ _+ — . — + 

SYNC | 



.— + — — +- 



|FL1| CASP5 | 729 |ALPS3 

| BYTE | INST I RXj RY J SPC X 

+.-. — +.—+_—_-+- — .-.+ 

"END RMC MODE" 

"RESTORE PSW FROM 1ST COMPARE** 
% AT>DB>SA 
% ADT>AB>SA 



+ + — -.-+ 

|FM1| CASP6 | 369 | 



-+ 

X 

NIL 
X 
X 
X 

LDPStt 
NF 
NOD 

1/08 

— +— -+—__.+ 



■+-+- 



.+-+. 



.+ + 



| IRSZ|INST| RX| RW2| . I 
+——+——+——+— — —+_——.+— ...i 



"STORE 2ND DEST VALUE" 

REGA>AB>ALD>RW2D 

-1>ALD 

RW2D>DB>FOOLIT 
% AT>DB>SAA 
% AOT>AB>SAA 



+ — _. 



X 
AND 
X 
X 
X 

NONE 
TPF 
TOD 

1/08 
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|FH1| CASP7 I 36a I 

♦ 

{ f]™f T j DT I RY| 

"INSTALL 1ST POINTER"" 
DT>DB»IRA 

"MOVE 1ST DEST. VALUE" 
AT> AB> > REGA 
% AUT>DB>SAA 



X 

MIL 
X 
X 
X 

NONE 
NF 
STIRA 



|P01| CASP8 I 36b I 
+ +-+ + _J + _ 

j_f R ffjf N f T l RX| RW2| . 

"STORE 1ST DEST VALUE""* 
REGA> AB> ALU > RW2D 
-1>ALD 

RW20>OB>FOOLIT 
% AT>OB>SAA 
% AOT>AB>SAA 



+ ♦ + + I 1/21 

]_DB_ j 



I 



X 

AND 
X 
X 
X 

NONE 
TPP 
TOD 

1/08 



i™i-?ff!! + -.i.!?i i 2 - W Ay"sHARE"|"kr~j" 
I fjfNSTj""" + "ra|" + ""^]""7 + "| 

t«m_zz~~_ "* + + ~~ 



PREFETCH 
% AT>DB>SA 
% ADT>AB>SA 



+ 



X 

NIL 
X 
X 

COL1 
STINS 
TPF 
TOD 

11/21 
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1ST COMPARE SUCCESSFUL 
+~ — + 



(CASP4) 



"WAIT POR BRANCH* 
% AT>DB>SA 
% AOT>AB>SA 



— *— .-+ — - — + 

X 
NIL 
X 
X 
X 

%STPSW 
NF 
NOD 

1/23 

— -+— — + 

LOCZ -> CASP11 (FN2) 
~LOCZ -> CASP10 (FN3) 



+ 2ND^COMPARE SUCCESSFUL ' (CASP9) 
| FN2 | CASP11 | "73r|"2lwArSHARE"l"DB""I 
j^ffffjDATAj RQ2Dj DTY j <W> T0 RMC | 



WRITE 2ND UPDATE" 
R02D> AB»DOB 
"PT @ 1ST MEM LOCATION" 
ADT>DB>AOB 

"INSTALL 1ST POINTER" 

DTX>DB»IRA 

% AT>AB>SAA 



X 
NIL 
X 
X 
X 

NONE 
NF 
STIRA 

1/06 



] c aspIi"~7fn27 i 'IV] 

l-l ?f f !f?f T 1 R02D I " "dtx| "<w>"i 0"*r^c"*"| 



"WRITE 1ST UPDATE" 

R02D>AB»DOB 

% AOT>DB>AOB 

% DTY>DB»IRA 

% AT>AB>SAA 
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— * — — +- — — ———.„+«. + 

]fff]_CASP13 | 454 | CASH 6 (PF2) | Db"~| 

[ X | INST | RXj RY| SPc"x"" + SYNc"| 



"END RMC MODE" 
% AT>DB>SA 
% AOT>AB>SA 



X 
NIL 
X 

I X 
% C0L1 

%STINS 

NF 

NOD 

«. 1/23 

SHARE | DB | 



|ET7| DBCC4 I 629 j 2-WAY 

+ +— + +-| 

| fjfNSTj RXJ RY| , 

"REFETCH NEXT INST"" 
% AT>DB>SA 
% AUT>AB>SA 



X 
NIL 
X 
X 
X 

CLRFP 
3PPI 
30DI 



+ +--- + t + H/21 

I 

X 
NIL 
X 
X 

COL1 
STINS 
3PPP 
3UDF 

11/21 



|ED7J DBCC5 I 783 I 

+ +-+ +— + +-i *■ 

] f |INST| RX| RY | 

"FINISH 3 WORD FETCH"""* 
% AT>DB>SA 
% AOT>AB>SA 
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2ND COMPARE UNSUCCESSFUL 



(CASP9) 



|FN3| CASP10 | 739 |PSPF2 (GJ8) I OB I 

+—+-+— — + — + — + 4— + 

I XjlHSTj RX| RYj SPC X SYNC 

"END SMC MODE" 
% R£GB>DB>AU>AOB * 
% 18>AO 
% AUT>AB>SA 




CASP6 



(FM1) 



RTE DEST FOR PAPA CAS 
♦ + + + 



|FH2 j CASPR 
+.-.+-+—-+. 
| X|INST| 



| 455 JCASM1 
DTj RY | 



(FA1) | DB | 
— — +- + 

I 



"INITIALIZE IRC2 (FOR RTE) • 
OT>DB»IRA 

"LATCH RMC ADDRESS INTO A4" 
% REGB> AB > > REGA 
% CT>ALU>ALDT 
% AT>DB>SAA 
% AUT>AB>SAA 



X 

AND 
X 
X 
X 

STCRC 
NF 
STIRA 



CASP2 



1/23 
(FH1) 
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Claims 



1. in a data processor, a method for changing a value at a 
first location and a value at a second location, the method 
comprising the steps of: 

providing as a first compare value the value at the 

first location; 
providing as a second compare value the value at the 

second location; 
providing a selected first swap value; 
providing a selected second swap value; and then 
performing in an uninterruptable sequence the steps of: 
comparing the first compare value to the value at 

the first location; 
comparing the second compare value to the value at 

the second location; and 
if both of the first and second compare values are 
the same as the respective values at the 
first and second location; 
storing the first swap value at the. first 

location; and 
storing the second swap value at the second 
location. 

2. In a data processor, a method for changing the contents 
of a linked, list which requires changing contents at two 
pointer locations in order to effect a change in said list, 
the method comprising the steps of: 

providing as a first compare value the value at a first 

pointer location; 
providing as a second compare value the value at a 

s cond pointer location; 
providing a selected first swap value; 
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providing a selected second swap value; and 
performing in an uninterruptable sequence the steps of: 
comparing the first compare value to the value at 

said first pointer location; 
comparing the second compare value to the value at 

said second pointer location; and 
if both of the first and second compare values are 
the same as the respective values at the 
first and second pointer locations; 
storing the first swap value as the value at 
the first pointer location; and 
storing the second swap value as the value at 
the second pointer location. 
3. In a data processor having a linked list which has an 
access counter associated therewith wherein contents at a 
pointer location and at the access counter are changed in 
order to effect a change in the list, a method for 
effecting a change in the list, comprising the steps of: 
preparing for the excution of an instruction to be 
performed by the data processor by: 

storing a first compare value, said first compare 
value read at a said pointer location which 
must be altered to effect said change in the 
list; 

storing a second compare value, said second 

compare value read at the access counter; 

storing a first swap value, said first swap value 
to be swapped for the value present at the 
pointer location in order to effect said 
change in the list; and 

storing a second swap value, said second swap 

value to be inserted into the access counter; 
and 
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executing the instruction, wh r in the instruction 
writes the first swap value into the pointer 
location and writes the second swap value 
into the access counter if, after the 
instruction commences, the value present at 
the pointer location is the same as the. first 
compare value and the value present at the 
access counter is the same as the second 
compare value. 

4. In a data processor, means for changing the contents of 
a linked list which requires changing contents of first and 
second pointer locations, comprising: 

means for providing as a first compare value the value 

at said first pointer location; 
means for providing as a second compare value the value 

at said second pointer location; 
means for providing a first swap value; 
means for providing a second swap value; and 
means for performing in an uninterruptable sequence the 

steps of: 

comparing the first compare value to the value at 
said first pointer location; 

comparing the second compare value to the value at 
said second pointer location; and 

if both of the first and second compare values are 
the same as the respective values at the 
first and second pointer location then: 
storing the first swap value as the value at 

first pointer location; and 
storing the second swap value as the value at 
the second pointer location. 

5. in a data processor having a linked list which has an 
acc 68 counter associated therewith wherein contents at a 
pointer location and at the access counter are 
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changed in order to effect a ctaang in the list # means for 
effecting a change in the list, comprising: 

means for preparing for the excution of an instruction 

to be performed by the data processor in which 

said means for preparing: 

stores a first compare value, said first compare 
value read at said pointer location which 
must be altered to effect said change in the 
list; 

stores a second compare value, said second compare 

value read at the access counter; 
stores a first swap value, said swap value to be 

swapped for the value present at said pointer 
location in order to effect said change In 
the list; and 
stores a second swap value, said second swap value 
to be inserted into the access counter to be 
incremented; and 
means for executing the instruction, wherein the 
instruction writes the first swap value into 
pointer location and writes the second swap value 
to the access counter if, after the instruction 
commences, the value present at the first pointer 
location is the same as the first compare value 
and the value present at the access counter is the 
same as the second compare value. 
6. In a data processor, means for changing the contents of 
a value at a first location and a value at a second 
location, comprising: 

means for providing as a first compare value the value 

at said first location; 
means for providing as a second compare value the value 

at said second location; 
means for providing a first swap value; 
means for providing a second swap value; and 
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means for performing in an uninterruptable sequence the 
steps of: 

comparing the first compare value to the value at 
said first location; 

comparing the second compare value to the value at 
said second location; and 

if both of the first and second compare values are 
the same as the respective values at the 
first and second locations then: 
storing. the first swap value as the value at 
the first location; and 

storing the second swap value as the value' at 
the second location. 
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COMPARE AND SWAP 2 
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1 



RETURN FROM BUS ERROR 
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1 



J 



READ FIRST TEST VALUEj 



J 
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SUBTRACT FIRST COMPARE 
VALUE FROM FIRST 
TEST VALUE. 



I 



SUBTRACT SECOND COMPARE 
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TEST VALUE. 
STORE FIRST OPERATION 
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NO 
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RESTORE PSW FROM I 
FIRST COMPARE. 
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.SECOND COMPARE. 
JQUA1S SECOND. 
.TEST. 



END RMC CYCl£| 



STORE SECOND TEST 
VALUE IN SECOND 
COMPARE REGISTER 



STORE FIRST TEST 

VALUE IN FIRST 
COMPARE REGISTER! 



YES 



WRITE SECOND SWAP 
VALUE TO SECOND 
TEST LOCATION. 



I 



WRITE FIRST SWAP 
VALUE TO FIRST 
TEST LOCATION 



END RMC CYCLE| 
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